package cn.com.mrzheng.cloud.springcloud.cfgbeans;

import com.netflix.loadbalancer.IRule;
import com.netflix.loadbalancer.RetryRule;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;

@Configuration
public class ConfigBean {

    @Bean
    @LoadBalanced//Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端       负载均衡的工具。
    public RestTemplate getRestTemplate()
    {
        return new RestTemplate();
    }

    @Bean
    public IRule myRule()    // Ribbon 负载均衡算法选择
    {
        //  return new RoundRobinRule();
        //  return new RandomRule();//达到的目的，用我们重新选择的随机算法替代默认的轮询。
          return new RetryRule();   // 轮回，当多次访问无效排除服务，重新轮回
//        return new RandomRule_ZJW();  // 自定义版本
    }

}
